package com.vehiclemanagement.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.ToString;

import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 加油记录实体类
 */
@Data
@ToString(callSuper = true)
@TableName("fuel_refill")
public class FuelRefill implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 加油记录ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 车辆ID
     */
    @TableField("vehicle_id")
    private Long vehicleId;

    /**
     * 驾驶员ID
     */
    @TableField("driver_id")
    private Long driverId;

    /**
     * 加油卡ID
     */
    @TableField("fuel_card_id")
    private Long fuelCardId;

    /**
     * 加油时间
     */
    @TableField("refill_time")
    private LocalDateTime refillTime;

    /**
     * 油品类型：1-92号汽油，2-95号汽油，3-98号汽油，4-0号柴油，5-其他
     */
    @TableField("fuel_type")
    private Integer fuelType;

    /**
     * 加油量（升）
     */
    @TableField("fuel_amount")
    private BigDecimal fuelAmount;

    /**
     * 单价（元/升）
     */
    @TableField("unit_price")
    private BigDecimal unitPrice;

    /**
     * 总金额（元）
     */
    @TableField("total_price")
    private BigDecimal totalPrice;

    /**
     * 当前里程表读数
     */
    @TableField("current_mileage")
    private Double currentMileage;

    /**
     * 备注
     */
    @TableField("remark")
    private String remark;

    /**
     * 创建时间
     */
    @TableField("create_time")
    private LocalDateTime createTime;

    /**
     * 更新时间
     */
    @TableField("update_time")
    private LocalDateTime updateTime;

    /**
     * 删除标志：0-未删除，1-已删除
     */
    @TableField("del_flag")
    @TableLogic
    private Integer delFlag;
    
    /**
     * 非数据库字段 - 车牌号
     */
    @TableField(exist = false)
    private String plateNumber;
    
    /**
     * 非数据库字段 - 驾驶员姓名
     */
    @TableField(exist = false)
    private String driverName;
    
    /**
     * 非数据库字段 - 加油卡号
     */
    @TableField(exist = false)
    private String fuelCardNumber;
    
    /**
     * 非数据库字段 - 油品类型名称
     */
    @TableField(exist = false)
    private String fuelTypeName;
} 